package com.member.shop.domain;

import com.baomidou.mybatisplus.annotation.IdType;
import com.baomidou.mybatisplus.annotation.TableField;
import com.baomidou.mybatisplus.annotation.TableId;
import com.baomidou.mybatisplus.annotation.TableName;
import com.fasterxml.jackson.annotation.JsonFormat;
import com.member.common.annotation.Excel;
import com.member.common.core.domain.BaseEntity;
import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor;
import lombok.experimental.SuperBuilder;

import java.math.BigDecimal;
import java.util.Date;

/**
 * 用户充值列表对象 sys_biz_recharge_user
 *
 * @author lixinchen
 * @date 2024-05-09
 */
@Data
@SuperBuilder
@AllArgsConstructor
@NoArgsConstructor
@TableName("sys_biz_recharge_user")
public class SysBizRechargeUser extends BaseEntity {

    private static final long serialVersionUID = 1L;

    /**
     * 自增ID
     */
    @TableId(type = IdType.AUTO)
    private Long id;

    /**
     * 充值配置id
     */
    private Long rechargeId;

    /**
     * 订单号
     */
    @Excel(name = "充值订单号")
    private String orderId;

    /**
     * 用户昵称
     */
    @Excel(name = "用户昵称")
    @TableField(exist = false)
    private String nickName;

    /**
     * 手机号
     */
    @Excel(name = "手机号")
    @TableField(exist = false)
    private String userPhone;


    /**
     * 充值用户id
     */
    private Long userId;

    /**
     * 充值前余额
     */
    @Excel(name = "充值前余额")
    private BigDecimal rechargeBalanceBefore;

    /**
     * 充值金额
     */
    @Excel(name = "充值金额")
    private BigDecimal rechargePrice;

    /**
     * 赠送金额
     */
    @Excel(name = "赠送金额")
    private BigDecimal givePrice;


    /**
     * 充值后余额
     */
    @Excel(name = "充值后余额")
    private BigDecimal rechargeBalanceAfter;

    /**
     * 支付状态(0:未支付，1:已支付,3支付超时)
     */
    private Integer paymentStatus;

    /**
     * 来源(1:线上，2:代充)
     */
    private Integer rechargeSource;

    /**
     * 支付流水号
     */
    private String paymentNo;

    /**
     * 支付时间
     */
    @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss")
    @Excel(name = "充值时间", width = 30, dateFormat = "yyyy-MM-dd HH:mm:ss")
    private Date payTime;

    /**
     * 支付截止时间
     */
    @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss")
    private Date payTimeEnd;

    /**
     * 微信流水号
     */
    private String transactionId;


    /**
     * 赠送类型（0 余额 1 优惠券）
     */
    private Integer giveType;
    /**
     * 优惠券id
     */
    private Long couponId;
    /**
     * 优惠券领取记录id
     */
    private Long couponReceiveId;


    /**
     * 支付方式 (0 微信 1 支付宝  3 余额)
     */
    private Integer paymentType;


    /**
     * 支付凭证
     */
    private String paymentCertificate;


    /**
     * 审核状态  0 未审核 1 审核通过 2 审核不通过 线上订单直接审核通过
     */
    private Integer auditStatus;

    /**
     * 审核原因
     */
    private String auditReason;

    /**
     * 充值订单状态
     */
    private Integer status;

    /**
     * 销售业务员（销售归属人）
     */
    private Long salesUserId;


}
